

## Learn Git and GitHub without any code!

Using the Hello World guide, you'll start a branch, write comments, and open a pull request.

Read the guide







| Time<br>Interval                      | Number of clk periods | Number of clk<br>periods in hex |          | Number of clk periods in binary |
|---------------------------------------|-----------------------|---------------------------------|----------|---------------------------------|
|                                       |                       |                                 |          |                                 |
| 2 ms                                  | 200 000               | 1                               | x"3_0d40 | "                               |
| b"0011_0000_1101_0100_0000"           |                       |                                 |          |                                 |
| 4 ms                                  | 400 000               |                                 | x"6_1A80 | "                               |
| b"0110_0001_1010_1000_0000"           |                       |                                 |          |                                 |
| 10 ms                                 | 1 000 000             | 1                               | x"F_4240 | "                               |
| b"1111_0100                           | 0_0010_0100_0000"     | 1                               |          |                                 |
| 250 ms                                | 25 000 000            | 1                               | x"17D_78 | 40"                             |
| b"0001_0111_1101_0111_1000_0100_0000" |                       |                                 |          |                                 |
| 500 ms                                | 50 000 000            | I                               | x"2FA_F0 | 80"                             |
| b"0010_1111_1010_1111_0000_1000_0000" |                       |                                 |          |                                 |
| 1 sec                                 | 100 000 000           | I                               | x"5F5_E1 | 00"                             |
| b"0101_111:                           | 1_0101_1110_0001_000  | 0_0000"                         |          |                                 |

## 2. Seven-segment display decoder

```
-- TEST COUNTER DIRECTION HERE
          if (cnt up i = '1') then
              s_cnt_local <= s_cnt_local + 1;</pre>
          else
              s_cnt_local <= s_cnt_local - 1;</pre>
          end if;
       end if;
   end if;
end process p_cnt_up_down;
-- Output must be retyped from "unsigned" to "std_logic_vector"
cnt_o <= std_logic_vector(s_cnt_local);</pre>
p_reset_gen : process
begin
   s_reset <= '0';</pre>
   wait for 12 ns;
   -- Reset activated
   s_reset <= '1';</pre>
   wait for 73 ns;
   s_reset <= '0';
   wait;
end process p_reset_gen;
______
-- Data generation process
-----
p_stimulus : process
begin
   report "Stimulus process started" severity note;
   -- Enable counting
   s_en <= '1';
   -- Change counter direction
   s cnt up <= '1';
   wait for 380 ns;
   s cnt up <= '0';
   wait for 220 ns;
   -- Disable counting
   s_en <= '0';
   report "Stimulus process finished" severity note;
   wait;
end process p_stimulus;
```



## 3. Top Level

```
-- Architecture body for top level
_____
architecture Behavioral of top is
   -- Internal clock enable
  signal s_en : std_logic;
   -- Internal counter
  signal s_cnt : std_logic_vector(4 - 1 downto 0);
begin
   -- Instance (copy) of clock_enable entity
   clk_en0 : entity work.clock_enable
      generic map(
          g_MAX \Rightarrow g_MAX
      port map(
          --- WRITE YOUR CODE HERE
       clk => CLK100MHZ,
      reset => BTNC,
      ce_o => s_en
       );
   -- Instance (copy) of cnt_up_down entity
   bin_cnt0 : entity work.cnt_up_down
      generic map(
          --- WRITE YOUR CODE HERE
               g_CNT_WIDTH => g_CNT_WIDTH
       port map(
           --- WRITE YOUR CODE HERE
```

```
clk => CLK100MHZ,
       reset => BTNC,
       en_i => s_en
       cnt_up_i => SW,
       cnt_o => s_cnt
       );
   -- Display input value on LEDs
   LED(3 downto 0) <= s_cnt;</pre>
   _____
   -- Instance (copy) of hex 7seg entity
   hex2seg : entity work.hex_7seg
       port map(
           hex_i
                  => s_cnt,
           seg_o(6) \Rightarrow CA,
           seg_o(5) \Rightarrow CB,
           seg_o(4) \Rightarrow CC,
           seg_o(3) \Rightarrow CD,
           seg_o(2) \Rightarrow CE,
           seg_o(1) \Rightarrow CF,
           seg_o(0) \Rightarrow CG
       );
   -- Connect one common anode to 3.3V
   AN <= b"1111_1110";
end architecture Behavioral;
```

